草庐IT

Springcloud Gateway网关日志这样打才完美

全部标签

ruby - 将 "puts"命令输出重定向到日志文件

我正在使用daemonsgem在Ruby中创建一个守护进程。我想将守护进程的输出添加到日志文件中。我想知道将puts从控制台重定向到日志文件的最简单方法是什么。 最佳答案 如果您需要同时捕获STDERR和STDOUT并且不想求助于日志记录:$stdout.reopen("my.log","w")$stdout.sync=true$stderr.reopen($stdout)恢复:$stdout=STDOUT 关于ruby-将"puts"命令输出重定向到日志文件,我们在StackOverf

ruby - 观看/阅读不断增长的日志文件

我有一个不断增长的日志文件。我如何通过Ruby脚本查看和解析它?脚本将解析写入文件的每个新行,并在新行包含字符串'ERROR'时将内容输出到屏幕 最佳答案 defwatch_for(file,pattern)f=File.open(file,"r")f.seek(0,IO::SEEK_END)whiletruedoselect([f])line=f.getsputs"Foundit!#{line}"ifline=~patternendendwatch_for("g.txt",/ERROR/)感谢ezpz的想法,使用select方法你

ruby-on-rails - 如何在 Rails 中为每个表创建完整的审计日志?

我们最近开始在我们公司插入合规性,并且需要保留对我们当前在Rails应用程序中管理的数据更改的完整历史记录。我们已经获准将每个操作的描述性内容简单地推送到日志文件,这是一种相当不引人注目的方式。我倾向于在ApplicationController中做这样的事情:around_filter:set_logger_usernamedefset_logger_usernameThread.current["username"]=current_user.login||"guest"yieldThread.current["username"]=nilend然后创建一个看起来像这样的观察者:c

ruby - "puts"输出未显示在 Sinatra 应用程序的 Heroku 日志中

我正在尝试使用“puts”来测试托管在Heroku上的Sinatra应用程序的一些内容。有趣的是,输出似乎排队并且仅在重新启动Herokudyno时显示。我尝试过使用“Thin”和“Webrick”,但遇到了同样的问题。有什么想法吗? 最佳答案 正如您在herokudocs上看到的那样:将此添加到您的config.ru:$stdout.sync=true不要忘记stdout之前的$否则它不会工作。 关于ruby-"puts"输出未显示在Sinatra应用程序的Heroku日志中,我们在S

ruby - 是否可以在 Ruby 中启用 TLS v1.2?如果是这样,如何?

是否可以将TLSv.1.2或TLSv1.1与Ruby一起使用?我使用OpenSSL1.0.1c(最新可用)编译了一个Frankenstein版本的Ruby,唯一的区别是SSLv2现在是OpenSSL::SSL::SSLContext::METHODS下的一个选项是否可以将TLSv1.2添加到该列表? 最佳答案 是的,我们添加了TLS1.1和1.2支持recently.就像在SSLContext上设置ssl_version一样简单:ctx=OpenSSL::SSL::SSLContext.newctx.ssl_version=:TLS

Ruby: 没有这样的文件或目录 @ rb_sysopen - testfile (Errno::ENOENT)

我想写一些东西到一个文件。#whereuseridisanyintger[sic]path=Rails.root+"public/system/users/#{user.id}/style/img.jpg"File.open(path,'wb')do|file|file.putsf.readend执行此代码时,出现此错误。我知道这个文件夹不存在,但是File.open和w模式会创建一个新文件(如果它不存在)。为什么这不起作用? 最佳答案 尝试在rake任务中使用gets?您可能会看到此错误消息:Errno::ENOENT:Nosuc

ruby - 为什么像 1 + n *= 3 这样的语句在 Ruby 中是允许的?

许多Ruby文档中的优先级表列出了二进制算术运算的优先级高于其相应的复合赋值运算符。这让我相信像这样的代码不应该是有效的Ruby代码,但它确实是。1+age*=2如果优先规则是正确的,我希望上面的代码会像这样用括号括起来:((1+age)*=2)#ERROR:Doesn'tcompile但事实并非如此。那么什么给呢? 最佳答案 正在检查ruby-y输出,您可以确切地看到正在发生的事情。鉴于1+age*=2的来源,输出表明会发生这种情况(简化):tINTEGER找到,识别为simple_numeric,这是一个numeric,这是一个

ruby - 没有这样的文件或目录 - getcwd

我将我的Sinatra应用程序上传到Beanstalk。当我访问我的站点时,我的日志被返回Nosuchfileordirectory-getcwd该应用程序之前运行正常。我认为这个问题与我将SASS添加到我的应用程序这一事实有关,但我并不肯定。在我的config.ru中,我有以下处理SASS的代码...#usescssforstylesheetsSass::Plugin.options[:style]=:compresseduseSass::Plugin::Rack如果这可能是另一个问题,请告诉我,我可以提供更多信息。谢谢。 最佳答案

ruby-on-rails - logger.debug 不写入 Rails 中的日志文件

我正在尝试在Rails中调试模型,因此我使用了以下代码:logger.debug('asasd')但是,我正在跟踪日志文件development.log,但我没有看到它添加到此文件中。我确定这个模块正在运行我已确认运行时错误正在记录到此文件中,并且我在tail时看到了它们。我如何让它工作? 最佳答案 确保您已将日志级别设置为在environments/appropriate_env_file.rb中进行调试:config.log_level=:debug并确保您根据运行环境跟踪正确的日志文件。

ruby - 如何在像 nginx 这样的代理后面时在 rails 日志中记录真实的客户端 ip

问题我在两台服务器上安装了Rails3.2.15和机架1.4.5。第一个服务器是服务于静态Assets的nginx代理。第二台服务器是为Rails应用程序提供服务的unicorn。在Railsproduction.log中,我总是看到nginxIP地址(10.0.10.150)而不是我的客户端IP地址(10.0.10.62):StartedGET"/"for10.0.10.150at2013-11-2113:51:05+0000我想在日志中有真实的客户端IP。我们的设置HTTPheaderX-Forwarded-For和X-Real-IP在nginx中设置正确,我已经定义了10.0.1